<template>
  <div>
    <el-card class="box-card" style="width: 400px">
      <div slot="header" class="clearfix">
        <span>{{admin.name}}</span>
      </div>
      <div>
        <div style="display: flex;justify-content: center">
          <el-upload
            class="upload-demo"
            :headers="headers"
            :data="admin"
            show-file-list="false"
            action="admin/userface"
            :on-success="onSuccess"
          >
            <img :src="admin.userFace" alt="" style="height: 100px;width: 100px;border-radius: 50px;"/>
          </el-upload>
        </div>
        <div>电话号码:<el-tag>{{admin.telephone}}</el-tag></div>
        <div>手机号码:<el-tag>{{admin.phone}}</el-tag></div>
        <div>居住地址:<el-tag>{{admin.address}}</el-tag></div>
        <div>用户标签:<el-tag v-for="(role,index) in admin.roles" :key="index">{{role.nameZh}}</el-tag></div>
        <div style="display: flex;justify-content: space-around;margin-top: 10px">
          <el-button type="primary" @click="showUpdateAdminInfoView">修改信息</el-button>
          <el-button type="danger" @click="showUpdateAdminPasswordView">修改密码</el-button>
        </div>
      </div>
    </el-card>
    <el-dialog
      title="编辑用户信息"
      :visible.sync="dialogVisible"
      width="30%">
     <div>
       <table>
         <tr>
           <td>用户昵称:</td>
           <td><el-input v-model="admin2.name" /></td>
         </tr>
         <tr>
           <td>电话号码:</td>
           <td><el-input v-model="admin2.telephone" /></td>
         </tr>
         <tr>
           <td>手机号:</td>
           <td><el-input v-model="admin2.phone" /></td>
         </tr>
         <tr>
           <td>用户地址:</td>
           <td><el-input v-model="admin2.address" /></td>
         </tr>
       </table>
     </div>
      <span slot="footer" class="dialog-footer">
    <el-button @click="dialogVisible = false">取 消</el-button>
    <el-button type="primary" @click="updateAdminInfo">确 定</el-button>
  </span>
    </el-dialog>
    <el-dialog
      title="更新密码"
      :visible.sync="passwordDialogVisible"
      width="30%">
      <el-form :model="ruleForm" status-icon :rules="rules" ref="ruleForm" label-width="100px" class="demo-ruleForm">
        <el-form-item label="请输入旧密码" prop="oldPass">
          <el-input type="password" v-model="ruleForm.oldPass" autocomplete="off"></el-input>
        </el-form-item>
        <el-form-item label="请输入密码" prop="pass">
          <el-input type="password" v-model="ruleForm.pass" autocomplete="off"></el-input>
        </el-form-item>
        <el-form-item label="确认新密码" prop="checkPass">
          <el-input type="password" v-model="ruleForm.checkPass" autocomplete="off"></el-input>
        </el-form-item>
        <el-form-item>
          <el-button type="primary" @click="submitForm('ruleForm')">提交</el-button>
          <el-button @click="resetForm('ruleForm')">重置</el-button>
        </el-form-item>
      </el-form>
    </el-dialog>
  </div>
</template>

<script>
import {getRequest} from "../utils/api";

export default {
  name: "AdminInfo",
  data(){
    var validatePass = (rule, value, callback) => {
      if (value === '') {
        callback(new Error('请输入密码'));
      } else {
        if (this.ruleForm.checkPass !== '') {
          this.$refs.ruleForm.validateField('checkPass');
        }
        callback();
      }
    };
    var validatePass2 = (rule, value, callback) => {
      if (value === '') {
        callback(new Error('请再次输入密码'));
      } else if (value !== this.ruleForm.pass) {
        callback(new Error('两次输入密码不一致!'));
      } else {
        callback();
      }
    };
    return {
      headers:{
        Authorization: window.sessionStorage.getItem('tokenStr')
      },
      admin:null,
      dialogVisible:false,
      passwordDialogVisible:false,
      admin2:null,
      ruleForm: {
        pass: '',
        checkPass: '',
        oldPass: ''
      },
      rules: {
        pass: [
          { validator: validatePass, trigger: 'blur' }
        ],
        checkPass: [
          { validator: validatePass2, trigger: 'blur' }
        ],
        oldPass: [
          { validator: validatePass, trigger: 'blur' }
        ]
      }
    }
  },
  created() {
    this.indata();
  },
  methods:{
    onSuccess(){
      this.indata();
    },
    submitForm(formName) {
      this.$refs[formName].validate((valid) => {
        if (valid) {
          this.ruleForm.adminId = this.admin.id;
          this.putRequest("/admin/pass",this.ruleForm).then(resp=>{
            if(resp){
                this.postRequest('logout');
                window.sessionStorage.removeItem('user');
                window.sessionStorage.removeItem('tokenStr');
                this.$store.commit('initRoutes',[]);
                this.$router.replace('/');
            }
          });
        } else {
          console.log('error submit!!');
          return false;
        }
      });
    },
    resetForm(formName) {
      this.$refs[formName].resetFields();
    },
    showUpdateAdminPasswordView(){
      this.passwordDialogVisible = true;
    },
    updateAdminInfo(){
      this.putRequest("/admin/info",this.admin2).then(resp=>{
        if(resp){
          this.dialogVisible = false;
          this.indata();
        }
      });
    },
    indata(){
      getRequest("/admin/info").then(res=>{
        console.log(res)
        this.admin = res;
        this.admin2 = Object.assign({},this.admin);
        window.sessionStorage.setItem('user',JSON.stringify(res));
        this.$store.commit('INIT_CURRENTAdmin',res);
      });
    },
    showUpdateAdminInfoView(){
      this.dialogVisible = true
    }
  }
}
</script>

<style scoped>

</style>
